**![Logo

Description automatically generated](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHkAAAB1CAMAAABd5r4AAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAJDUExURf///97KrcCXXb6WXL+XXNO2i/39/Pz6+Mytf9G0i/j18EVZZgdBaglCaghCaiRQbL2WXMCZYLaUZRVHbbuUXs6whi9NarSTaMCXXJiBY1pgar+XXQNAaAM8ZgM9Z/j4+QY6ZklJguHj6baSXx9Hcfn5+sytgf7+/s7T2YiVqvLr35mDarzCzvv7+8SaXgVAajtafRdHbqmvwIORqAA9aThMecGZYAM+aufp7a6OYrO3w19ukMXK09nDovLy9QY/aAdBabqUXi9OeJylugRBafPz93KCnwQ+Z8nN2dLU3ePm65ijtExsigZAaRlJcBVFbWRzigNBaQhBaQdCagA8Z4aPoyFIdAE9Zr6WW4GPp//+/pV+Zy9OdwZBagU9ZiZPd/Hz9b+XXgM7ahtGaRM9bfb39wI3ZAdAaCBHariSXKCEXgZBaUJVaL+WWwhAabyUXL2VXAQ/aAA0Z3CBmvz8/QI/afPz9Yl2Y35vZL6XXYKLo494ZFdebJumugA2ZQdAauXn7Orh1wExZcCdbJ6DYTJMaGx7l3BpZAE4ZO7v87mTXOXWxIKQqJWkuARAaNve5AdAabWQXTdQZ9W9mAQ8Zr+WXAFAadPV3UdggBVIdv7+/wY8ZyVLa4SSpQAzZwA/amx9k/T19/n29D5ZfQE+avv7/czO2tG4mQY4ZKaIYbK3yiFIatze5XB7ml1uktnCoY59a8moeOrdywVCau7j1drEpFZha+/l2A9CatzGpw1CasajcQ5Eav///v79/Pfy6wAAAAAd6RIAAADBdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wCINFSNAAAACXBIWXMAACHVAAAh1QEEnLSdAAAKWklEQVRoQ+1bPatkxxGdDcwL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) San Francisco Bay University**

**EE461 Digital Design and HDL**

**Week#8 UART Design**

**VI. Exercises**

Complete UART receiver and transmitter RTL design modules and verify them in the testbenches.

**UART Receiver**

module UARTRx(

input wire clk,

input wire reset,

input wire rx,

output reg [7:0] data,

output reg valid

);

// Declare variables

reg [2:0] state;

reg [3:0] bitCounter;

reg [7:0] shiftReg;

// Declare parameters for FSM

parameter IDLE = 3'b000;

parameter START = 3'b001;

parameter RECEIVE = 3'b010;

parameter STOP = 3'b011;

// FSM: Synchronous Sequential block & Combinational block

always @(posedge clk, posedge reset) begin

if (reset) begin

state <= IDLE;

bitCounter <= 4'd0;

shiftReg <= 8'd0;

valid <= 1'b0;

end else begin

case(state)

IDLE: begin

if(!rx) begin

state <= START;

bitCounter <= 4'd1;

shiftReg <= 8'd0;

end

end

START: begin

shiftReg <= {shiftReg[6:0], rx};

bitCounter <= bitCounter + 1;

if(bitCounter == 4) begin

state <= RECEIVE;

bitCounter <= 4'd1;

end

end

RECEIVE: begin

shiftReg <= {shiftReg[6:0], rx};

bitCounter <= bitCounter + 1;

if(bitCounter == 8) begin

state <= STOP;

bitCounter <= 4'd1;

end

end

STOP: begin

shiftReg <= {shiftReg[6:0], rx};

bitCounter <= bitCounter + 1;

if(bitCounter == 9) begin

state <= IDLE;

bitCounter <= 4'd0;

data <= shiftReg[7:0];

valid <= 1'b1;

end

end

endcase

end

end

// Implementation

always @(\*) begin

case(state)

IDLE: begin

valid <= 1'b0;

end

START: begin

valid <= 1'b0;

end

RECEIVE: begin

valid <= 1'b0;

end

STOP: begin

valid <= 1'b0;

end

endcase

end

endmodule

**TestBench**

module UARTRx\_tb;

reg clk;

reg reset;

reg rx;

wire [7:0] data;

wire valid;

UARTRx uartrx(

.clk(clk),

.reset(reset),

.rx(rx),

.data(data),

.valid(valid)

);

initial begin

$dumpfile("UARTRx\_tb.vcd");

$dumpvars(0, UARTRx\_tb);

clk = 0;

reset = 1;

rx = 1;

#10 reset = 0;

#10 rx = 0;

#5 rx = 1;

#5 rx = 0;

#5 rx = 1;

#5 rx = 0;

#5 rx = 1;

#5 rx = 0;

#5 rx = 1;

#5 rx = 0;

#5 $finish;

end

always #5 clk = ~clk;

endmodule

**UART Transmitter**

module UARTTx(

clk,

rst\_i,

byteReady\_i,

load\_i,

TxByte\_i,

busData\_i,

serialOut\_o

);

input clk;

input rst\_i;

input byteReady\_i;

input load\_i;

input TxByte\_i;

input[7:0] busData\_i;

output serialOut\_o;

parameter pIdle=2'b00;

parameter pWait=2'b01;

parameter pSend=2'b10;

reg[1:0] curSt\_r;

reg[1:0] nxtSt\_r;

reg loadData\_r;

reg start\_r;

reg clr\_r;

reg shift\_r;

reg[3:0] cnt\_r;

reg[7:0] busReg\_r;

reg[8:0] dataReg\_r;

//Sequential Logic

always@(posedge clk)begin

if(rst\_i)begin

curSt\_r <= pIdle;

end

else begin

curSt\_r <= nxtSt\_r ;

end

end

// Combo Logic

always@(\*)begin

loadData\_r=1'b0;

start\_r=1'b0;

clr\_r=1'b0;

shift\_r=1'b0;

nxtSt\_r= curSt\_r;

case(curSt\_r)

pIdle: begin

if(byteReady\_i)begin

loadData\_r=1'b1;

nxtSt\_r=pWait;

end

end

pWait: begin

if(TxByte\_i)begin

start\_r = 1'b1;

nxtSt\_r= pSend;

end

end

pSend: begin

if(cnt\_r ==9)begin

clr\_r = 1'b1;

nxtSt\_r= pIdle;

end

else begin

shift\_r = 1'b1;

end

end

default: begin

nxtSt\_r= pIdle;

end

endcase

end

//Implementation block- bit counter

always@(posedge clk)begin

if(rst\_i)begin

cnt\_r<=4'b0000;

end

else if(clr\_r)begin

cnt\_r<=4'b0000;

end

else if(shift\_r)begin

cnt\_r<= cnt\_r + 1'b1;

end

end

always@(posedge clk)begin

if(rst\_i)begin

busReg\_r <=8'b0000\_0000;

dataReg\_r<=9'b1\_1111\_1111;

end

else if(load\_i)begin

busReg\_r <= busData\_i;

end

else if(loadData\_r)begin

dataReg\_r <= {busReg\_r, 1'b1};

end

else if(start\_r)begin

dataReg\_r[0]<=1'b0; //output startbit ==0;

end

else if(shift\_r)begin

dataReg\_r<={1'b1, dataReg\_r[8:1] };

end

end

assign serialOut\_o = dataReg\_r[0];

endmodule

**Testbench**

`timescale 1ns/10ps

module UARTTx\_tb;

// Inputs

reg clk;

reg rst\_i;

reg byteReady\_i;

reg load\_i;

reg TxByte\_i;

reg [7:0] busData\_i;

// Outputs

wire serialOut\_o;

// Instantiate the UARTTx module

UARTTx dut (

.clk(clk),

.rst\_i(rst\_i),

.byteReady\_i(byteReady\_i),

.load\_i(load\_i),

.TxByte\_i(TxByte\_i),

.busData\_i(busData\_i),

.serialOut\_o(serialOut\_o)

);

// Clock generator

always begin

clk = 1'b0;

#5;

clk = 1'b1;

#5;

end

// Stimulus

initial begin

$dumpfile("UARTTx\_tb.vcd");

$dumpvars(0, UARTTx\_tb);

rst\_i = 1'b1;

byteReady\_i = 1'b0;

load\_i = 1'b0;

TxByte\_i = 1'b0;

busData\_i = 8'b0000\_0000;

#50;

rst\_i = 1'b0;

byteReady\_i = 1'b1;

busData\_i = 8'b0101\_0101;

#100;

byteReady\_i = 1'b0;

load\_i = 1'b1;

#20;

load\_i = 1'b0;

#20;

TxByte\_i = 1'b1;

#100;

$finish;

end

endmodule